2

3

## What is claimed is:

| 1   | 1.                    | An apparatus for processing information wherein processing operations                 |
|-----|-----------------------|---------------------------------------------------------------------------------------|
| 2   | include a plura       | ality of tasks, at least one of the plurality of tasks having a critical section, the |
| 3   | apparatus comprising: |                                                                                       |
| 4   |                       | a first processing element, said first processing element including:                  |
| 5   |                       | a critical section end detector, and                                                  |
| 6   |                       | a critical section end signal generator coupled to said critical section end          |
| 7   | detector; and         |                                                                                       |
| 8   | a seco                | nd processing element, said second processing element coupled to said first           |
| 9   | processing ele        | ement and including:                                                                  |
| 10  |                       | a critical section detector, and                                                      |
| 11  |                       | a critical section processing controller, said critical section processing            |
| 12  | contro                | ller responsive to a critical section end signal received from said first processing  |
| 13  | eleme                 | nt                                                                                    |
| 1   | 2                     | The apparatus of claim 1, said second processing element further including a          |
| 1   | 2.                    | The apparatus of claim 1, said second processing element further merating a           |
| 2   | count                 | er, said critical section processing controller incrementing said counter in          |
| . 3 | respor                | nse to a critical section end signal.                                                 |

3. The apparatus of claim 1, said second processing element further including a counter, said critical section processing controller decrementing said counter based on the detection of a critical section.

The principal of the pr

1

2

3

1 4. The apparatus of claim 1, said second processing element further including a 2 counter, said critical section processing controller suspending issuing instructions when said 3 counter includes a value less than a threshold.

The apparatus of claim 1, wherein said first processing element sends a critical section end signal to said second processing element in response to processing an instruction identifying an end of a critical section.

1 6. The apparatus of claim 1, wherein said second processing element suspends 2 processing a task in response to said critical section detector detecting a critical section.

7. The apparatus of claim 1, wherein said critical section processing controller suspends issuing instructions to an instruction unit in response to said critical section detector detecting a critical section.

- 1 8. The apparatus of claim 7, wherein a critical section instruction identifies a 2 beginning of a critical section in the task at said second processing element.
- 1 9. The apparatus of claim 7, wherein the critical section includes an instruction 2 that accesses a shared variable.

13

| 1  | 10. The apparatus of claim 7, wherein the critical section includes an instruction           |  |  |
|----|----------------------------------------------------------------------------------------------|--|--|
| 2  | that accesses a shared peripheral.                                                           |  |  |
|    |                                                                                              |  |  |
| 1  | 11. The apparatus of claim 1, wherein said critical section end signal generator             |  |  |
| 2  | generates a critical section end signal in response to said critical section end detector.   |  |  |
|    |                                                                                              |  |  |
| 1  | 12. An apparatus for processing multiple data elements wherein processing                    |  |  |
| 2  | operations include a plurality of tasks, one or more of which having a critical section, the |  |  |
| 3  | apparatus comprising:                                                                        |  |  |
| 4  | a ring of processing elements;                                                               |  |  |
| 5  | a first processing element in said ring of processing elements, said first processing        |  |  |
| 6  | element including:                                                                           |  |  |
| 7  | a critical section end detector, and                                                         |  |  |
| 8  | a critical section end signal generator; and                                                 |  |  |
| 9  | a second processing element in said ring of processing elements, said second                 |  |  |
| 10 | processing element coupled to said first processing element, and including:                  |  |  |
| 11 | a critical section detector, and                                                             |  |  |

responsive to a critical section end signal received from said first processing element.

a critical section processing controller, said critical section processing controller

- 1 13. The apparatus of claim 12, wherein said first processing element sends a
- 2 critical section end signal in response to processing an instruction identifying an end of a
- 3 critical section.
- 1 14. The apparatus of claim 12, wherein said second processing element suspends
- 2 processing a task in response to said critical section detector.
- 1 15. The apparatus of claim 12, wherein said second processing element suspends
- 2 processing a task at a critical section instruction.
- 1 16. The apparatus of claim 12, wherein said first processing element and said
- 2 second processing element are adjacent in said ring of processing elements.
- 1 17. The apparatus of claim 16, wherein said first processing element is upstream
- 2 from said second processing element in said ring of processing elements.
- 1 18. The apparatus of claim 12, said second processing element further including a
- 2 counter, said critical section processing controller incrementing said counter in response to a
- 3 critical section end signal.

4

5

6

| 1 | 19.            | The apparatus of claim 12, said second processing element further including a |
|---|----------------|-------------------------------------------------------------------------------|
| 2 | counter, said  | critical section processing controller decrementing said counter based on the |
| 3 | detection of a | critical section                                                              |

- 1 20. The apparatus of claim 12, said second processing element further including a 2 counter, said critical section processing controller suspending issuing instructions when said 3 counter includes a value less than a threshold.
- 1 21. A method for processing tasks on multiple processing elements, comprising: 2 processing a task on a first processing element;
  - inhibiting processing of a task on a second processing element based on processing a critical section instruction at the second processing element;
  - receiving a critical section end signal at the second processing element, the critical section end signal indicating completion of processing of a critical section of a task at another processing element; and
- resuming processing the task at the second processing element based on the critical section end signal.
- 1 22. The method of claim 21, wherein said inhibiting occurs substantially at a 2 beginning of a critical section of the task at the second processing element.

2

3

4

1

2

1 23. The method of claim 21, wherein said resuming occurs substantially at an end 2 of a critical section of the task at the first processing element.

- The method of claim 21, wherein the first processing element and the second processing element are associated with a single network connection during the processing of the task associated with the first processing element and the task associated with the second processing element, respectively.
  - 25. The method of claim 21, wherein the first processing element and the second processing element are associated with different network connections during the processing of the task associated with the first processing element and the task associated with the second processing element, respectively.
  - 26. The method of claim 21, wherein said sending occurs in response to processing an critical section end instruction.
- 1 27. The method of claim 21, wherein said sending occurs in response to detecting 2 a critical section end instruction.

- 1 28. The method of claim 21, further comprising storing data to a memory shared
- 2 by the first processing element and the second processing element, said sending the critical
- 3 section end signal occurring in response to said storing.
- 1 29. The method of claim 21, wherein the task at the first processing element and
- 2 the task at the second processing element are associated with a single network connection.
- 1 30. The method of claim 21, wherein the task at the first processing element and
- 2 the task at the second processing element are associated with different network connections.
- 1 31. The method of claim 21, wherein the task at the first processing element and
- 2 the task at the second processing element are associated with ordered data elements.
- 1 32. The method of claim 21, wherein said sending occurs in response to processing
- 2 an instruction identifying an end of a critical section.
- 1 33. The method of claim 21, wherein said inhibiting occurs in response to
- 2 processing an critical section instruction.
- 1 34. The method of claim 33, wherein the critical section instruction identifies a
- 2 beginning of a critical section in the task at the second processing element.

6

7

- 1 35. The method of claim 33, wherein the critical section instruction is an 2 instruction accessing a shared variable.
- 1 36. The method of claim 33, wherein the critical section instruction is an 2 instruction accessing a shared peripheral.
- 1 37. A method for controlling access to shared resources while processing network 2 data elements on multiple processing elements, the method comprising:
- detecting a critical section instruction while processing a network data element at a first processing element;
  - prior to executing the critical section instruction, checking an end critical section signal counter associated with a second processing element; and
  - suspending execution of the critical section instruction when said end critical section signal counter is not above a threshold value.
- 1 38. The method of claim 37, wherein said suspending occurs substantially at a beginning of a critical section of a task at the first processing element.
- The method of claim 38, wherein said resuming occurs substantially at an end of a critical section of a task at second processing element.

1

1

1

The method of claim 37, further comprising resuming execution of the critical 40. 1 section instruction when the end critical section signal counter is determined to be above a 2

3 threshold value.

The method of claim 37, further comprising incrementing the end critical 41. 1

section signal counter upon receipt of an end critical section signal. 2

The method of claim 37, wherein said suspending occurs in response to 42. processing a critical section instruction. 2

The method of claim 42, wherein the critical section instruction identifies a 43. beginning of a critical section in the task at the first processing element. 2

- The method of claim 43, wherein the critical section includes an instruction 44. 1 that accesses a shared variable. 2
- The method of claim 43, wherein the critical section instruction includes an 45. 1 instruction that accesses a shared peripheral. 2
  - A method for performing parallel processing, comprising: 46.

1

2

1

2

1

2

- suspending processing of a task at a first processing element in response to detecting a beginning of a critical section of the task; and
- resuming processing of the task at the first processing element in response to a critical section end signal received from a second processing element.
- 1 47. The method of claim 46, wherein the first processing element and the second 2 processing element are coupled within a ring of processing element.
  - 48. The method of claim 46, further comprising prior to said suspending, checking an end critical section signal counter associated with a second processing element.
- 1 49. The method of claim 48, wherein said suspending occurs in response to 2 determining the end critical section signal counter is not above a threshold value.
  - 50. The method of claim 46, further comprising receiving an end critical section signal from a second processing element.
  - 51. The method of claim 46, further comprising incrementing an end critical section signal counter associated with the first processing element in response to receiving an end critical section signal from the second processing element.

6

9

10

| 1 | 52.            | The method of claim 46, wherein the first processing element and the second |
|---|----------------|-----------------------------------------------------------------------------|
| 2 | nrocessing ele | ment are adjacent within a ring of processing element.                      |

- 1 53. An apparatus for processing multiple data elements wherein processing operations include a plurality of tasks, one or more of which having a critical section, the apparatus comprising:
- 4 a ring of processing elements;
  - a first processing element in said ring of processing elements, said first processing element including:
- 7 a critical section operative state element, and
- 8 a critical section end signal generator; and
  - a second processing element in said ring of processing elements, said second processing element coupled to said first processing element, said second processing element including a critical section detector.
- The apparatus of claim 53, wherein said first processing element is adjacent to said second processing element in said ring of processing elements.
- 1 55. The apparatus of claim 53, wherein said second processing element suspends 2 processing a task at the beginning of a critical section.

| 1 | 56.             | The apparatus of claim 55, wherein the critical section includes an instruction |
|---|-----------------|---------------------------------------------------------------------------------|
| 2 | that accesses a | shared variable                                                                 |

- 1 57. The apparatus of claim 55, wherein the critical section includes an instruction 2 that accesses a shared peripheral.
- 1 58. A method for controlling access to shared resources while processing network 2 data elements on multiple processing elements, the method comprising:
- detecting a critical section instruction while processing a network data element at a first processing element;
- prior to executing the critical section instruction, checking a critical section processing controller associated with a second processing element; and
  - inhibiting execution of the critical section instruction when said critical section processing controller indicates that a critical section instruction should not be executed.
- 1 59. An apparatus for processing information wherein processing operations 2 include a plurality of tasks, one or more of which having a critical section, the apparatus 3 comprising:
- a first processing element in said ring of processing elements, said first processing element including:
- 6 a critical section end detector, and

| /  | a critical section end signal generator, and                                             |
|----|------------------------------------------------------------------------------------------|
| 8  | a second processing element in said ring of processing elements, said second             |
| 9  | processing element coupled to said first processing element, and including:              |
| 10 | a critical section end signal counter, said critical section end signal counter          |
| 11 | responsive to a critical section end signal received from said first processing element, |
| 12 | a critical section detector, and                                                         |
| 13 | a critical section processing controller, said critical section processing               |
| 14 | controller responsive to said critical section end signal counter.                       |
|    |                                                                                          |